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Subcode and sector synchronization for a data processing syetea* 

The present invention relates to the data synchronization 
between a data processing system and a servo -system for an 
apparatus for reading from and/or writing to optical recording 
media . 



in recent years an increasing need has been experienced for 
providing consumer electronic devices, like e.g. compact disc 
players, DVD-players and others, with the capability of 
processing audio data stored as audio files in a compressed 
(e.g, MP3 or MP3 Pro, WMA (Windows Media Audio)) or 
uncompressed (e.g. WAV (Waveform Audio Pile)) data format on a 
storage medium. In contrast to an Audio Processing System 
according to prior art, which can only read and/or write audio 
information according to the Compact Disc Standard (Red Book) , 
an advanced data processing system (DPS) capable of playing 
back and/or recording audio files in a compressed or 
uncompressed data format, needs to be able to extract, decode, 
and convey data related to the file system and the audio files 
stored on a storage medium. 



A CD (compact disc) decoder IC with embedded compressed audio 
decoding shall comprise two primary systems! An advanced data 
processing system (DPS) and a servo system (performing servo, 
data path and control operations) - The servo system contains i 
master micro controller. 



Throughout the description, the following definitions are used: 
Sector, Subcode address: 

All sector addresses and subcode time codes (sections) ^jre 
represented in the form min: sec : frame * The minutes field is 
represented by "min", the seconds field is represented by 
"sec", the blocks (sector) or frames (subcode) field is 
represented by "frame". 
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Session; 

An ar ea on a disc consisting of a Lead-in Area followed by a 
Program Area and a Lead-Out Area is called session. 



5 Single session disc? 

If a disc contains one session, this disc is called a single 
session disc. 

Multisession disc: 
10 If a disc contains more than one session, this disc is called a 
multisession disc. 

Sector: 

Whenever the term "sector 11 is used in this document, it has the 
15 identical meaning as the term "block" in the CD-ROM system 
description. 

DPS: 

(Advanced) Data Processing System. An example for such a data 
20 processing system is an advanced audio processing system, a 
module responsible for the extraction and interpretation of 
digital data tracks (Digital Tracks, as defined in ECMA-13G) in 
a storage medium, as well as decoding and playback of 
compressed audio data contained in the digital data tracks. 

25 

The DPS uses sectors (sector addresses) as its basic data 
structure while the servo system uses subcode -frames 
(sections) . 

30 The BCMA-130 standard provides the following definitions for 
sector and section of a compact disc; 

A sector is the smallest addressable part of the information 
area that can be accessed independently. 

A section (subcode- frame) is defined as a group of 98 P3 -frames 
35 containing a complete table of control bytes. A table is 
generated with the control bytes of each subcode- frame 
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(section) . The content of this table is renewed every 1/75 
second/ which is the same rate at which the subcode -frames are 
being processed. The table of control bytes of a subcode -frame 
defines the following channels: p-, g- , r-, s-, t-, u-, v- and 

5 w-channel of 96 bits each. The receiving end has particular 
interest in the g- channel that conveys, among others , 
information about the absolute time (subcode time code) of the 
section in the A-FRAC, A-SEC and A-MIN fields. These fields 
contain the absolute time in 75th of a second as a continuation 

10 of the time specified in the A-xxx fields of the q-channel of 
the preceding section* 

The address of a sector is recorded in the sector header. The 
address of the first sector with user data of an information 
track is written in the table of contents of the disc. 
15 The sector header conveys the address of a sector as an 

absolute time* At the encoder end, this address is inserted 
just before the sector enters a Cross Interleaved Reed- Solomon 
(CIRC) encoder. 



20 According to the ECMA 130 standard, the nominal value of a 
sector shall be egual to the absolute time recorded in the 
control bytes of that subcode-frame which is being processed by 
the 8-to-14 encoder at the time the sync word of the sector 
enters the CIRC encoder. 

25 

It is also stated in the ECMA- 130 standard that the address of 
the sectors has no prescribed relation to the address (subcode 
time code) of the sections! due to the fact that the mapping of 
a sector to the sections during recording is implementation 
30 dependent (ECMA-130 Standard, clause 16, PI Frame) . For this 
reason synchronization between sectors and subcode -frames is 
required at the receiving end. 



The decoder ic servo system processes the q-channel of the 
35 subcode~f rames . The micro controller has access to the q- 

channel data. Through this it has access to the CD's table of 




content* The table of content entries point to the start of 
information tracks on the disc, in terms of the absolute time 
in the control bytes, with an accuracy of */- 1 second. 
The tnicro controller has also access to the subcode absolute 
~~~5 time code in tne q-data fleia o£ trie information area. 

The DPS requests sectors from the micro controller. The micro 
controller organizes the task of delivering data to the DPS 
with the collaboration of an electronic shock proof micro 
controller (ESPMC) block, from which the DPS receives its input 
10 data . 

The DPS requests sectors using the sector address expressed in 
absolute time elapsed since the beginning of the user data 
area, in MSF (minutes, seconds, frames) units. The 
corresponding information in the servo system is the absolute 

15 time code part of the q-channel of a subcode frame, if no 

synchronisation between the subcode time code and the sector 
address is done, the DPS has to flush the data provided by the 
servo system until the requested data (sector) is received, 
which is time and memory consuming. If the time difference is 

20 known, the servo system can take this information into account 
when jumping to a requested time. 

- -It is, therefore, an object of the present invention to provide 
a method for synchronizing the subcode time codes and sector 
25 addressee of data contained on a recording medium. 

According to the invention, the method comprises the steps of: 

- sending a number of sectors from the micro controller to the 
data processing system; 

. 30 - requesting information about the sector- -headers of the - 
received seators from the data processing system; and 

- calculating the difference between the subcode time codes and 
the sector addresses using the information about the sector 
headers ♦ 




The method has the advantage that it will speed-up the access 
of the data processing system to the sector information 
provided by the servo -system. 

5 Favourably , the method further comprises the steps of t 

- asking the data processing system for a confirmation of 
seator reception; and 

- implementing a continuity counter in the data processing 
system to check if the expected sectors were received - 

10 In this way it is ensured that no sectors were missed/ which 
could otherwise lead to an incorrect synchronization between 
the subcode time codes and the sector addresses. 

Advantageously/ the method further comprises the step of 
15 storing the sectors in a memory. This allows further access to 
the sectors by subsequent additional commands from the micro, 
controller . 

According to the invention, absolute time information conveyed 
20 in the sector headers and in absolute time fields of the q- 
channel of the subcode frame is used for calculating the 
difference between the subcode time codes and the sector 
addresses. Using this information the synchronization between 
the subcode time codes and the sector addresses can easily be 
25 achieved. 

Favourably, the method further comprises the step of repeating 
the synchronisation steps for every session on the recording 
medium. Since the difference can vary for different sessions on 
30 the same disc, this ensures synchronisation between the subcode 
time codes and the sector addresses for all sessions. 

According to the invention, a communication protocol for the 
communication between a data processing system and a micro 
35 controller defines a set of command© and messages necessary for 
synchronisation between subcode time codes and sector addresses 
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of data contained on a recording medium. Such a communication 
protocol allows to synchronize between two system© , where one 
system is working based on subcode information, and the other 
system is working based on sector information. 



Advantageously, the set of commands and messages defined for 
the communication protocol comprises commands for scanning 
sectors and for reading sector data and messages for sending 
information on the sectors and the read sector data. From the 
10 sector data, especially the sector header, all information 
necessary for synchronization can be retrieved. 

Favourably, a decoder for optical recording media performs a 
method or usee a communication protocol according to the 
IS invention. 



According to the invention, the inventive method, the inventive 
communication protocol, and/ or the inventive decoder is used in 
an apparatus for reading from and/or writing to optical 
20 recording media. 

In the following, the implementation of a communication 
protocol according to the invention will be explained in more 
detail. Commands are sent from the micro controller to the DPS, 
25 while messages are sent from the DPS to the micro controller. 



Synchronisation process: 

After the servo system has finished reading the table of 
content (TOG) , in case of single session disc, the micro 
30 controller will start an "analyse mode" on the DPS. In case of 
a multisession disc, the analyse mode can be started after the 
TOC of each session is read, or after all TOCs are read. 



Description of command and Message: 
Used command; SCAN <f ramexsecxmin> 
Used message: SCANM 
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Three different Modes for SCAN, depending on the transmitted 
frame ! seo tmin information are used. 



Mode 1: 

5 Requests to get information about the first valid sector which, 
can be received from the AIN-Mailbox (Audio- In Mailbox) . 
Before the servo system is sending a SCAN model command to the 
DPS, the ESPMC memory will be flushed and then e,g. 4 subcode 
frames are stored by the servo system into the ESPMC memory. 

10 The storing is to be understood as follows* In a playback mode 
the servo system searches for the specific subcode or jumps to 
the corresponding position on the disc. As soon as the subcode 
has been found, writing of data to the ESPMC is enabled/ the 
data coming from an error correction block. When a 

15 predetermined number of subcode- frames, e.g. four subcode- 
frames, has been written to the ESPMC, writing is disabled 
again. The micro controller does not write data to the ESPMC 
directly . 

The storage of data is based on the subcode information. By 
20 reading the data in the ESPMC via the DPS the header 

information (sector) can be accessed and the time difference 
between the stored subcode frame and the actually obtained 
sector can be calculated. 



25 Function; 

After receiving the SCAN model command from the servo system, 
the DPS starts reading data out of the AIN-Mailbox, while 
counting the flushed bytes, until a jSYNC word, followed by a 
header (1st header, i*e> 12 byte SYNC, followed by 4 bytes of 
30 non flagged data (C2_ERR = 0)) is found. The 1st header 
(4bytes) , followed by 233 6 bytes of data will be stored. 



The DPS has to check now, if the following SYNC-word and the 
following header (2nd header, i.e. 12 byte SYNC, followed by 4 
35 bytes of non flagged data (C2_SRR = o) ) are valid. The SYNC- 
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word and the 2nd header have to be stored to allow subsequent 
SCAN modes commands to operate on the same ESPMC data. 

The command will be aborted bv the DPS if the ES PMC memory 

5 becomes empty, or in case a number of byte counter has an 
overflow. 

The DPS will send a SCANM message to the servo system, carrying 
information on the 1st and 2nd valid headers, the number of 
10 counted bytes, which were flushed while reading the AIN-Mailbox 
until the 1st header was found, and an indicator indicating a 
number of byte counter overflow. 

The number of counted bytes should be normally less than the 
15 number of bytes of one sector (2352) . Otherwise, this would be 
an indication for the servo system that one sync -word, 
respectively header was not found. 

The information on the 1st and 2nd valid headers comprises 4 
20 byte header information (1st header) as coded on disc and 8 
byte subheader information (1st header) as coded on disc, and 
indicators indicating whether valid 1st and 2nd headers were 
found . 

25 After receiving the SGANM message, the servo system is able to 
calculate the time difference (in complete sectors) between 
subcode time code and sector addresses as follows 2 

time difference *= { [min: sec ; frame] subcode time code stored in 
30 ESPMC} - { [min: sec : frame] received 1st header information} 

Since only complete sectors can be taken into account by the 
servo system, the DPS has to search for the sync word and has 
to flush number of bytes when the delta is calculated. 
35 The exact delta will be: 
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time difference + {(number of byte-12) / 2352} 
Mode 2: 

Requests to search for sector [min: sec s frame] within the data 
5 which can be received from the AIN-Mailbox. 

Before the servo system is sending a SCAN mode2 command to the 
DPS, the ESPMC memory will be flushed and then the data to be 
analysed is stored into the ESPMC memory. 



10 Function: 

After receiving the SCAN mode2 command from the servo system/ 
the DPS starts reading data out of the' AIN-Mailbox, while 
counting the flushed bytes, until a SYNC word, followed by the 
requested header (1st header) is found. The 1st header 
15 (4bytes) , followed by 2336 bytes of data will be stored. 

The DPS has to cheak now if the following SYNC -word and the 
following header (2nd header) are valid. The SYNC-word and the 
2nd header have to be remembered to allow subsequent SCAN mode3 
20 commands to operate on the same ESPMC data. 

The command will be aborted by the DPS if the ESPMC memory 
becomes empty, or in case a number of byte counter has an 
overflow . 

25 

The DPS will send a SCANM message to the servo system, carrying 
information on the 1st and 2nd valid headers, the number of 
counted bytes, which were flushed while reading the AIlST-Mailbox 
until the 1st header was found, and an indicator indicating a 
30 number of byte counter overflow. 



The information on the 1st and 2nd valid headers comprises 4 
byte header information (1st header) as coded on disc and 8 
byte subheader information (1st header) as coded on disc, and 
35 indicators indicating whether valid 1st and 2nd headers were 
found . 
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After receiving the SCANM message, the servo system is able to 
calculate the time difference (number of frames) between 

subcode time code and sector addresses as follows; 

5 

time difference » {Number of counted bytes mod 2352} 
Mode 3: 

Requests information about the next sector (2nd valid sector of 
10 the previous scan) which can be received from the AIN~Mailbox. 
The servo system sends a SCAN mode3 command to the DPS „ This 
mode is only applicable, if scan model, scan mode2 or scan 
mode3 was sent before. If no scan was sent before or if no 2nd 
valid header was found before, the error message "command not 
IS available" will be returned. 

Function 

After receiving the SCAN mode3 command from the servo system/ 
the DPS continues reading data out of the AIN~Mailbox. The data 
20 will be stored into. No bytes will be flushed. 

The header and subheader information of the current sector, 
which was already read by the previous scan model or scan mode2 
command (previous 2nd valid header becomes "1st valid header) , 
will also be stored into. 

25 

The DPS has to check now if the following SYNC-word and the 
following header (new 2nd header) are valid. The SYNC-word and 
the 2nd header have to be stored to allow subsequent SCAN mode3 
commands to operate on the same ESPMC data. 

30 

The command will be aborted by the DPS, if the ESPMC memory 
becomes empty. 

The DPS will send a SCANM message to the servo system, carrying 
35 information about the 1st valid header and about whether a 2nd 
valid header was found- 
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The information about the 1st valid header comprises 4 byte 
header information as coded on disc and 8 byte subheader 
information as coded on disc, 

5 

Read lector data: 

As an option, and also to be flexible for further changes in 
the CD-Sector formats, the following access to the cd-rom data 
is proposed. The command and message described below allow to 
10 read the data (header and cd-rom data) as stored by previous 
scan commands. 

Description of command and Message: 
Used command! RSECDATA (Request Sector Data). 
15 Used message: SECDATA 

The command/ respectively message is only valid if a SCAN 
command was sent before. Otherwise an error message "command 
not available" will be returned. 

20 The RSECDATA command is called with 2 bytes (lower, higher) 
indicating the first value which will be requested. 

Function 

After receiving the RSECDAT command from the servo system# the 
25 Dps sends the requested data starting at the requested first 
value, to the micro controller using the SECDATA message. 

If the first requested value lies outside an allowed range, the 
error message "target not available" will be returned. 

30 

The inventive method is not limited to the communication in a 
CD-decoder. The method is applicable to any communication 
between two systems, where one system is working based on 
subcode information (like the servo system) , and the other 
35 system is working based on sector information (like the DPS) . 
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For a better understanding of the invention, an exemplary 
embodiment ia specified in the following description of an 
advantageous configuration with reference to the figure. It is 
understood that the invention is not limited to this exemplary 



embodiment and that specified features can also expediently be 
combined and/or modified without departing from the scope of 
the present invention. 



Fig, 1 shows an example for the SCAN model communication. 

10 

Fig. 1 show© an example for the SCAN model communication. Upon 
initialization/ the micro • controller 1 in a first step 4 has a 
number of sectors sent via a memory 2 (e.g. an electronic shock 
proof micro controller ESPMC) to the DPS 3. In a second step 5 

15 the micro controller 1 asks for a confirmation on sector 

reception, which is sent in a further step 6 from the DPS. For 
this purpose a continuity counter 7 is implemented in the DPS. 
To allow synchronization between the subcode time codes and the 
sector addresses, the micro controller in a step 8 requests 

20 information about the sector header fields using a SCAN model 
command. The DPS sends the requested information using a SCANM 
message. The micro controller is now able to calculate 9 the 
difference between the subcode time codes and the sector 
addresses. In the figure, two further communications steps are 

25 shown. Using a first read sector data command RSECDATAl, the 
micro controller 1 requests sector data from the DPS 3, which 
in response sends the requested data using a first sector data 
message SECDATAi. Further data is then exchanged via a second 
read sector data command RSECDATA2 and the corresponding sector 

30 data response SECDATA2 . 
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1. Method for synchronizing subcode time codes and sector 
addresses of data contained on a recording medium for the 
5 communication between a data processing system (3) and a micro 
controller (1), comprising the steps of! 

- sending (4) a number of sectors from the micro controller {1) 
to the data processing system (3) ; 

- requesting (8) information about the sector headers of the 
10 received sectors from the data processing system (3); and 

- calculating (9) the difference between the subcode time codes 
and the sector addresses using the information about the sector 
headers . 

15 2> Method according to claim 1, further comprising the steps of: 

- asking (5) the data processing system (3) for a confirmation 
of sector reception; and 

- implementing (7) a continuity counter in the data processing 
system (3) to check if the expected sectors were received. 

20 

3. Method according to claim 1 or 2, further comprising the step 
of storing the sectors in a memory (2) . 

4. Method according to any of claims 1-3, characterized in that 
25 absolute time information conveyed in the sector headers and in 

absolute time fields of the q-channel of the subcode frame is 
used for calculating the difference between the subcode time 
codes and the sector addresses. 

30 5. Method according to any of claims 1-4, further comprising the 
step of repeating the synchronisation steps (4-9) for every 
session on the recording medium. 

6 , Communication protocol for the communication between a data 
35 processing system (3) and a micro controller (1) , characterized 
in that a set of commands and messages necessary for 
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synchronization between subcode time codes and sector addresses 
of data contained on a recording medium is defined. 

7, Communication protocol according to claim 6, c harac terized in 
that the set of commands and messages comprises commands for 
scanning sectors and for reading sector data and messages for 
sending information on the sectors and the read sector data. 



8. Decoder for optical recording media, characterized in that it 
performs a method according to any of claims 1-5 or uses a 
communication protocol according to claim 6 or 7 . 

9. Apparatus for reading from and/ or writing to optical 
recording media, characterized in that it performs a method 
according to any of claims 1-5, uses a communication protocol 
according to claim 6 or 7, and/or uses a decoder according to 
claim 8 . 
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Abstract 



Subcode and sector synchronization for a data, processing system 

5 The present invention relates to the data synchronisation 

between a data processing system 3 and a servo -system 1 for an 
apparatus for reading from and/or writing to optical recording 
media. 

It is an object of the present invention to provide a method 
10 for synchronizing the subcode time codes and sector addressee 
of data contained on a recording medium. 

According to the invention/ the method comprises the steps of; 

- sending 4 a number of sectors from the micro controller 1 to 
the data processing system 3/ 

15 - requesting 8 information about the sector headers of the 
received sectors from the data processing system 3; and 

- calculating S the difference between the subcode time codes 
and the sector addresses using the information about the sector 
headers . 



20 



Fig. 1 
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